阅读更多

39顶
22踩

行业应用

原创新闻 为什么新人不会编程

2011-06-20 10:54 by 见习编辑 jobbole 评论(45) 有27367人浏览

  我们都生活在一个这样的噩梦中:一个新手开发人员前来工作,你欢迎他的参与,却发现他达不到你对进度的要求,而且他的提问也显示出他对基础知识的无 知。即使他最终把工作完成了,编写的程序也很笨拙,需要更能干的人从头重写。然而录取他的面试官们或人力资源部门(如果你的公司中也有这种官僚体制的寄生 虫的话)却信誓旦旦地表示,他们只聘用精英人才。

  这是一个大问题,尤其是现在,有愈演愈烈的趋势。每天我都从招聘人员那儿收到骚扰邮件,每个IT公司都极度渴望聘请程序开发者,但是优秀的程序员是不可替代的。一个优秀的程序员可以轻易完成相当于一个平庸的程序员五十倍的工作,而拙劣的程序员最终只会产生消极的生产力(参见《一些鲜为人知的编程真相》)。因此,对任何公司来说雇佣这样的人都 是一个可怕的错误;对新创公司来说,这简直就是具有毁灭性的公司杀手。既然这样,为什么这种情况出现得如此频繁呢?

  就如同有很多残留问题困扰着现代软件工程一样,这都是微软的错。当微软还是一个人人都暗自想去工作的邪恶帝国时,就以用令人绞尽脑汁的问题面试而著名。例如:为什么井盖是圆的?当然,他们也问刚毕业的大学生一些关于计算机科学理论的问题,如:请写一个二分查找程序。

  每个IT公司都希望能像微软一样,甚至Google也这么希望过,直到目前大家都想成为Google这样的公司。因此这种相互模仿的面试传统就延续 了下来。看看这两个关于面试问题的最新信息,一个来自准员工,一个来自Google面试官。这里引用了两句Google面试官说的话,很有启发性。“我甚至不必说这是一个 很好的标准。”和“如果 有任何值得欣慰的地方,至少我们再也不问复杂的谜语问题了,那个实在是相当令人反感。”

  令人高兴的是,Google似乎有点意识到他们的招聘方法存在问题,可惜的是他们没有设法解决。Jean Hsu也撰文表明她对技术面试效用的疑问。根本问题是,目前通过行业标准化的软件面试所需要的技能并不是一个优秀的软件开发人员所需要的技能,或许这其中有某些相关性,但这个相关性就跟奥克兰突袭者队挑选出跑得最快的人,却无尽沮丧地发现国家橄榄球联盟并不是一个跑步比赛是一样的。

  事实上更糟糕。因为至少接球员是需要跑的,而我却可以无所畏惧的向你保证,没有哪个被聘用的软件工程师必须写一个二分查找程序。这就如你选择承包商一 样, 因为他们知道怎样用煤、铁、炉子和风箱来锻造和浇铸钢材。事实上他们只需要知道最近的一家家得宝(全球最大的家居建材零售商,美国第二大零售商)的地址, 以及用在那里买的钢材来做什么用。

  你通常试图在雇员身上找寻的东西,Joel Spolsky曾给出了准确的解释,即:就是聪明(Smart)并且能做事(Get things done)的人。(大学院校中到处都是具备前者而不具备后者的人。)不过,首先你必须构建一些其它的能力,也就是说不能完全不具备任何能力。你会惊奇的发 现,如此多的完全不胜任的应聘者出现在技术面试中。Google的二分搜索大概是打算作为他们的“FizzBuzz”(分支切换)——一个你进入Google大门必须越过 的障碍。这个“FizzBuzz”在真正的面试开始前占据了足足五分钟。

  那么,一场真正的面试包括什么呢?请允许我提出一个愚见:不聘用没有任何成就的人。证书和学位从来都不是成就,我是指有实际用户的真实项目。现在 Google App Engine和Amazon Web Services提供免费的第三方服务,而且要注册成为一名Android开发人员,并在Android Market发布程序也总共只需25美元。在这样一个世界里,任何软件开发人员没有借口说他没有自己制作的网站、应用程序或服务。(编注:因此,新人在参 加全职工作前,去承接网站开发项目或者软件开发项目,从中学到的知识和积累的经验,对新人而言是一项非常宝贵的财富。)

  旧的面试体系以有限的信息为基础,你只能通过应聘者的简历了解他们。但是,如果你只面试有成就的人,你将会有一个更宽广的平台来开展工作。避开 “FizzBuzz”,直接让应聘者展示他们的代码,并解释他们的设计决策,如果让他们现在重新做的话,又会有什么不同。你在一旁观看时,让他们实现一个 或者两个功能,这样你就能知道他们实际上是怎样工作的以及他们在工作中的想法。这才是你想从一场技术面试中得到的,而不是通过一些过时的算法和数据结构来 对此进行估量。这个世界总在不断前进。


  原文:Jon Evans 翻译:唐瑭

来自: www.jobbole.com
39
22
评论 共 45 条 请登录后发表评论
45 楼 foxesabc 2011-08-18 23:12
你没当过新人?垃圾
44 楼 JAVA_静 2011-07-27 17:11
你这个傻逼
43 楼 dayang2001911 2011-06-29 14:40
这种方法好!
42 楼 同步卫星 2011-06-22 17:11
brentforwork 写道
1.标题和文章内容不符.
2.按照你的理论,程序员要编过程的,管理员要管理过项目的,老总要开过公司的,请问你现在是干什么的,你已经不能往上爬了,因为上面的你没做过.

同意这个观点!
都需要一个过程,过程中继续不断努力吧~~~
41 楼 brentforwork 2011-06-22 11:46
1.标题和文章内容不符.
2.按照你的理论,程序员要编过程的,管理员要管理过项目的,老总要开过公司的,请问你现在是干什么的,你已经不能往上爬了,因为上面的你没做过.
40 楼 shenliu 2011-06-22 11:25
都是 ‘传帮带’ 作者不要过来人 嫌弃新来人
39 楼 xsfcl174 2011-06-22 10:58
照LZ的意思就是说新人统统不要,只要有成绩的旧人,插,你是准备让我们这些新人没活路呢,还是咋的,你Y还不是被人从新人带上来的
38 楼 geminiyellow 2011-06-22 09:55
都他妈很牛掰啊。
37 楼 ziyuewang 2011-06-21 23:03
       
36 楼 cw550284 2011-06-21 22:28
又不想花钱,又想找好的,哪能呢
35 楼 wxn_yxm 2011-06-21 15:03
hantsy 写道
人多并不是力量大,过去一些工作经验表明,一些新人加入项目,会拖慢项目进度。。。过去一个项目中,我向公司上层直言过,再在20人的效率不如我们以前的5个人。

你这个有一定的道理,不过项目人多不能提高那涉及到管理的问题,不在此讨论范围
34 楼 wxn_yxm 2011-06-21 14:53
从开发人员的角度想,对新人要宽容,谁都想写出高质量的代码,需要经验积累。从另老技术员的角度想要让他们成长才是王道。没有天才的程序员,只有努力的程序员。
33 楼 szhnet 2011-06-21 14:40
明主 贤臣    可遇而不可求啊
32 楼 明日的艹泥马 2011-06-21 12:45
要以辩证的观点看问题,新人未必以后会比你差,人都是在进步的,没有谁天生就适合做程序员
31 楼 LiC_07093128 2011-06-21 11:25
全是扯淡!人不是生下来就会写程序的!即使是技术牛人也是从新人过来的!做IT这行需要的是激情,兴趣等一个新人怎么了!在后天的成长中也有可能成为牛人
何必这么打击新人啊  说实话有的新人说不定比你还牛
30 楼 tianhandigeng 2011-06-21 09:59
全他妈扯蛋!!
29 楼 hawelina 2011-06-21 09:47
哎,想说很多,又觉得说不出来,新人表示压力很大。
新人也想写好代码,可是写不出来。。代码表示压力很大
28 楼 mqyl1 2011-06-21 09:26

   都可以成为面霸的
27 楼 hatedance 2011-06-21 09:11
guys, it's a blog, not a news.
26 楼 tom&jerry 2011-06-21 08:23
引用
为什么井盖是圆的?


微软说他们重来没有出过这样的面试题,都是外人编造的。

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 容器网络的灵活使用

    本篇是第七部分“网络篇”的第二篇。在这个部分,我会为你由浅入深的介绍 Docker 网络相关的内容。包括 Docker 网络基础及其实现和内部原理等。上篇,我为你介绍了如何使用用户自定义的 bridge 网络。本篇,我们将学习如何灵活的使用容器网络。 Docker 在网络方面也提供了多种功能,可用于满足不同的需求。本篇,我来为你介绍几种灵活使用 Docker 网络的方法。 域名解析 上篇我...

  • 查找局域网广播风暴的工具及NetworkActivPIAFCTMv的使用教程

    查找局域网广播风暴的工具 局域网广播风暴检测监听软件 内附详细图文教程一看就会 NetworkActivPIAFCTMv的用法

  • 网络调试指令ping、telnet、curl

    背景:最近遇到了复杂网络下的网络联通测试,记录一下命令 一、ping 命令 ping命令用来测试主机之间网络的连通性。执行ping指令会使用ICMP传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常;若远端主机断开网络连接,就不会有回应信息; ping无法检查系统端口是否开放。 ping baidu.com PING baidu.com (123.125.115.110): 56 data bytes 64 bytes from 123.1..

  • WireShark网络安全之链路层安全-广播风暴

    影响:ARP和DHCP在局域网中广播,占用网络资源 网络性能下降 原因: 1.网络短路 2.网络存在回路 3.网卡损坏 4.蠕虫病毒 ////////////////// 说白了就是数据包在网络中来回穿梭 没人要 或者是有人要了但是又抛弃了 反正就是数据包没有归路 然后越来越多 形成网络拥堵 ...

  • 如何向目标IP地址发送数据包…

    原文地址:如何向目标IP地址发送数据包呢作者:wshuyun89 ping IP或是主机名 它发送的实际上是一个ICMP数据包。 不知道你有没有基础,看看下面的吧 是DOS命令,一般用于检测网络通与不通 PING (Packet Internet Grope),因特网包探索器,用于测试网络连接量的程序。Ping发送一个ICMP回声清求消息给目的地并报告是否收到所希望的ICMP回声应答...

  • Windows网络诊断和配置常用命令详解

    Windows网络诊断和配置常用命令详解

  • 测试网络性能系列之netperf 与网络性能测量

    本文首先介绍网络性能测量的一些基本概念和方法,然后结合 netperf 工具的使用,具体的讨论如何测试不同情况下的网络性能。 在构建或管理一个网络系统时,我们更多的是关心网络的可用性,即网络是否连通,而对于其整体的性能往往考虑不多,或者即使考虑到性能的问题,但是却发现没有合适的手段去测试网络的性能。 当开发出一个...

  • 网络风暴简介

    什么是网络风暴?         由于网络拓扑的设计和连接问题,或其他原因,导致广播在网段内大量复制,传播数据帧,导致网络性能下降,甚至网络瘫痪。这样的现象就是网络风暴。 怎样抑制网络风暴?         广播域:是在在网端上,所有设备的集合。这些设备可以接听送往每个网段的所有广播。         冲突域:在同一个冲突域中的每一个节点都能收到所有被发送的帧。         冲突域基于第...

  • 网络风暴

    刚刚经历了一下网络风暴。导致服务器不能启动了。 原因可能是网络形成了环路,导致的。 可能是我这里通过bub连接了2个网口,2个网口间又有数据转发造成的。

  • windows常用的DNS测试命令

    Windows系统域名解析测试

  • [计算机通信网络]跳(hop) 的概念,tracert指令来查看访问站点经过了多少个路由器

    跳(hop)的概念,windows的tracert指令

  • ARP局域网检测工具

    很好用的ARP局域网检测工具,专门针对局域网内的ARP攻击,可以扫描到攻击源。方便大家对局域网的维护、诊断。

  • 如何利用IP标识查找网络风暴

    一、什么是广播风暴 广播风暴,顾名思义,即网络中的广播信息所占用的时间非常多,从而对正常的信息传输产生影响,轻则造成传送信息延时,重则造成网络性能急剧下降,甚至造成整个网络的堵塞、瘫痪,这就是广播风暴。那么,产生广播风暴常见的原因有哪些呢? 二、广播风暴产生的原因 产生广播风暴的原因,通常有以下几种: 1. 网络设备:网络设备原因,如网卡,当网卡...

  • H3C 广播风暴

    转载于:https://www.cnblogs.com/fanweisheng/p/11169888.html

  • 网络只是个工具

    2019独角兽企业重金招聘Python工程师标准>>> ...

  • tracert-命令小结

          前言:今天在阅读“Web性能权威指南”这本书的时候,发现 tracert 这个命令挺有意思的,在分析网络性能瓶颈的时候也能使用的到,在此就小记一笔以备后用。 1:作用 tracert 是一个简单的网络诊断工具,可以列出分组经过的路由节点,以及它在IP 网络中每一跳的延迟。(这里的延迟是指:分组从信息源发送到目的地所需的时间,延迟也分为许多的种类——传播延迟、传输延迟、处理延迟、排队...

  • Tracert命令 路由跟踪数据包解析

    Tracertet 命令作为一个路由跟踪、诊断实用程序,在DOS和UNIX系统下都有此命令,它通过发送 Internet 控制消息协议 (ICMP) 回显请求和回显答复消息,产生关于经过每个路由器的命令行报告输出,从而跟踪路径。该程序是网管必备的TCP/IP工具之一,经常被用于测试网络的连通性,确定故障位置。因此,我们有必要通过对Tracert路由跟踪数据包的精确解析,完整了解Tracert命令的...

Global site tag (gtag.js) - Google Analytics